home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Aminet 1 (Walnut Creek)
/
Aminet - June 1993 [Walnut Creek].iso
/
aminet
/
misc
/
sci
/
ephem_src_4_28.lha
/
constel.c
< prev
next >
Wrap
C/C++ Source or Header
|
1992-04-17
|
20KB
|
553 lines
#include <math.h>
#include "astro.h"
#include "screen.h"
#include "circum.h"
/* print the constellation object p is in now as a prompt message.
*/
constellation_msg (p, np)
int p;
Now *np;
{
char buf[NC];
char *name;
Sky s;
(void) body_cir (p, 0.0, np, &s);
confnd (s.s_ra, s.s_dec, epoch == EOD ? mjd : epoch, &name);
sprintf (buf, "In %s", name);
f_msg (buf);
}
/*
METHOD TO DETERMINE THE CONSTELLATION IN WHICH A POSITION IS LOCATED
C version by Craig Counterman and Elwood Downey,
adapted from fortran version:
exerpt from accompanying doc file:
Recently, Mr. Barry N. Rappaport of New Mexico State University
transcribed the constellation boundaries as fixed by the IAU into
machine-readable form. These have been transcribed by Dr. Nancy G.
Roman to make it possible to determine by computer the constellation
in which a position is located.
NSSDC catalog description:
6042 AN Catalog of Constellation Boundary Data (Delporte, E. 1930,
Cambridge Univ. Press)
Comment(s): includes constellation identification software
(ADC 1987; see Roman, N.G. 1987, Publ. Astron. Soc. Pacific
99, 695); 23 description, 118 software, 358 data records.
3 files: 23x80, 118x80, 358x29
full documentation file:
METHOD TO DETERMINE THE CONSTELLATION IN WHICH A POSITION IS LOCATED
Recently, Mr. Barry N. Rappaport of New Mexico State University trans-
cribed the constellation boundaries as fixed by the IAU into machine-readable
form. These have been transcribed by Dr. Nancy G. Roman to make it possible to
determine by computer the constellation in which a position is located.
Two files follow. The first is a program, in FORTRAN77, for determining
the constellation using the data in the succeeding file. Comments describe
the format in which the positions must be entered. The main program is
followed by a precession subroutine.
The final file is a list of constellation boundaries in the form Lower
Right Ascension (F8.4), Upper Right Ascension (F8.4), Lower Declination (F9.4),
three letter abbreviation for the Constellation (1X,A3). The file contains
358, 29-byte records.
The following is an example of the output of the program:
RA = 9.0000 DEC = 65.0000 IS IN CONSTELLATION UMa
RA = 23.5000 DEC = -20.0000 IS IN CONSTELLATION Aqr
RA = 5.1200 DEC = 9.1200 IS IN CONSTELLATION Ori
RA = 9.4555 DEC = -19.9000 IS IN CONSTELLATION Hya
RA = 12.8888 DEC = 22.0000 IS IN CONSTELLATION Com
RA = 15.6687 DEC = -12.1234 IS IN CONSTELLATION Lib
RA = 19.0000 DEC = -40.0000 IS IN CONSTELLATION CrA
RA = 6.2222 DEC = -81.1234 IS IN CONSTELLATION Men
END OF INPUT POSITIONS AFTER: RA = 6.2222 DEC = -81.1234
THE EQUINOX FOR THESE POSITIONS IS 1950.0
*/
static char And[] = "And: Andromeda";
static char Ant[] = "Ant: Antlia";
static char Aps[] = "Aps: Apus";
static char Aql[] = "Aql: Aquila";
static char Aqr[] = "Aqr: Aquarius";
static char Ara[] = "Ara: Ara";
static char Ari[] = "Ari: Aries";
static char Aur[] = "Aur: Auriga";
static char Boo[] = "Boo: Bootes";
static char CMa[] = "CMa: Canis Major";
static char CMi[] = "CMi: Canis Minor";
static char CVn[] = "CVn: Canes Venatici";
static char Cae[] = "Cae: Caelum";
static char Cam[] = "Cam: Camelopardalis";
static char Cap[] = "Cap: Capricornus";
static char Car[] = "Car: Carina";
static char Cas[] = "Cas: Cassiopeia";
static char Cen[] = "Cen: Centaurus";
static char Cep[] = "Cep: Cepheus";
static char Cet[] = "Cet: Cetus";
static char Cha[] = "Cha: Chamaeleon";
static char Cir[] = "Cir: Circinus";
static char Cnc[] = "Cnc: Cancer";
static char Col[] = "Col: Columba";
static char Com[] = "Com: Coma Berenices";
static char CrA[] = "CrA: Corona Australis";
static char CrB[] = "CrB: Corona Borealis";
static char Crt[] = "Crt: Crater";
static char Cru[] = "Cru: Crux";
static char Crv[] = "Crv: Corvus";
static char Cyg[] = "Cyg: Cygnus";
static char Del[] = "Del: Delphinus";
static char Dor[] = "Dor: Dorado";
static char Dra[] = "Dra: Draco";
static char Equ[] = "Equ: Equuleus";
static char Eri[] = "Eri: Eridanus";
static char For[] = "For: Fornax";
static char Gem[] = "Gem: Gemini";
static char Gru[] = "Gru: Grus";
static char Her[] = "Her: Hercules";
static char Hor[] = "Hor: Horologium";
static char Hya[] = "Hya: Hydra";
static char Hyi[] = "Hyi: Hydrus";
static char Ind[] = "Ind: Indus";
static char LMi[] = "LMi: Leo Minor";
static char Lac[] = "Lac: Lacerta";
static char Leo[] = "Leo: Leo";
static char Lep[] = "Lep: Lepus";
static char Lib[] = "Lib: Libra";
static char Lup[] = "Lup: Lupus";
static char Lyn[] = "Lyn: Lynx";
static char Lyr[] = "Lyr: Lyra";
static char Men[] = "Men: Mensa";
static char Mic[] = "Mic: Microscopium";
static char Mon[] = "Mon: Monoceros";
static char Mus[] = "Mus: Musca";
static char Nor[] = "Nor: Norma";
static char Oct[] = "Oct: Octans";
static char Oph[] = "Oph: Ophiuchus";
static char Ori[] = "Ori: Orion";
static char Pav[] = "Pav: Pavo";
static char Peg[] = "Peg: Pegasus";
static char Per[] = "Per: Perseus";
static char Phe[] = "Phe: Phoenix";
static char Pic[] = "Pic: Pictor";
static char PsA[] = "PsA: Piscis Austrinus";
static char Psc[] = "Psc: Pisces";
static char Pup[] = "Pup: Puppis";
static char Pyx[] = "Pyx: Pyxis";
static char Ret[] = "Ret: Reticulum";
static char Scl[] = "Scl: Sculptor";
static char Sco[] = "Sco: Scorpius";
static char Sct[] = "Sct: Scutum";
static char Ser[] = "Ser: Serpens";
static char Sex[] = "Sex: Sextans";
static char Sge[] = "Sge: Sagitta";
static char Sgr[] = "Sgr: Sagittarius";
static char Tau[] = "Tau: Taurus";
static char Tel[] = "Tel: Telescopium";
static char TrA[] = "TrA: Triangulum Australe";
static char Tri[] = "Tri: Triangulum";
static char Tuc[] = "Tuc: Tucana";
static char UMa[] = "UMa: Ursa Major";
static char UMi[] = "UMi: Ursa Minor";
static char Vel[] = "Vel: Vela";
static char Vir[] = "Vir: Virgo";
static char Vol[] = "Vol: Volans";
static char Vul[] = "Vul: Vulpecula";
struct cdata {
double l_ra, u_ra, l_dec;
char *cons;
} con_data[] = {
{0.0000, 24.0000, 88.0000, UMi},
{8.0000, 14.5000, 86.5000, UMi},
{21.0000, 23.0000, 86.1667, UMi},
{18.0000, 21.0000, 86.0000, UMi},
{0.0000, 8.0000, 85.0000, Cep},
{9.1667, 10.6667, 82.0000, Cam},
{0.0000, 5.0000, 80.0000, Cep},
{10.6667, 14.5000, 80.0000, Cam},
{17.5000, 18.0000, 80.0000, UMi},
{20.1667, 21.0000, 80.0000, Dra},
{0.0000, 3.5083, 77.0000, Cep},
{11.5000, 13.5833, 77.0000, Cam},
{16.5333, 17.5000, 75.0000, UMi},
{20.1667, 20.6667, 75.0000, Cep},
{7.9667, 9.1667, 73.5000, Cam},
{9.1667, 11.3333, 73.5000, Dra},
{13.0000, 16.5333, 70.0000, UMi},
{3.1000, 3.4167, 68.0000, Cas},
{20.4167, 20.6667, 67.0000, Dra},
{11.3333, 12.0000, 66.5000, Dra},
{0.0000, 0.3333, 66.0000, Cep},
{14.0000, 15.6667, 66.0000, UMi},
{23.5833, 24.0000, 66.0000, Cep},
{12.0000, 13.5000, 64.0000, Dra},
{13.5000, 14.4167, 63.0000, Dra},
{23.1667, 23.5833, 63.0000, Cep},
{6.1000, 7.0000, 62.0000, Cam},
{20.0000, 20.4167, 61.5000, Dra},
{20.5367, 20.6000, 60.9167, Cep},
{7.0000, 7.9667, 60.0000, Cam},
{7.9667, 8.4167, 60.0000, UMa},
{19.7667, 20.0000, 59.5000, Dra},
{20.0000, 20.5367, 59.5000, Cep},
{22.8667, 23.1667, 59.0833, Cep},
{0.0000, 2.4333, 58.5000, Cas},
{19.4167, 19.7667, 58.0000, Dra},
{1.7000, 1.9083, 57.5000, Cas},
{2.4333, 3.1000, 57.0000, Cas},
{3.1000, 3.1667, 57.0000, Cam},
{22.3167, 22.8667, 56.2500, Cep},
{5.0000, 6.1000, 56.0000, Cam},
{14.0333, 14.4167, 55.5000, UMa},
{14.4167, 19.4167, 55.5000, Dra},
{3.1667, 3.3333, 55.0000, Cam},
{22.1333, 22.3167, 55.0000, Cep},
{20.6000, 21.9667, 54.8333, Cep},
{0.0000, 1.7000, 54.0000, Cas},
{6.1000, 6.5000, 54.0000, Lyn},
{12.0833, 13.5000, 53.0000, UMa},
{15.2500, 15.7500, 53.0000, Dra},
{21.9667, 22.1333, 52.7500, Cep},
{3.3333, 5.0000, 52.5000, Cam},
{22.8667, 23.3333, 52.5000, Cas},
{15.7500, 17.0000, 51.5000, Dra},
{2.0417, 2.5167, 50.5000, Per},
{17.0000, 18.2333, 50.5000, Dra},
{0.0000, 1.3667, 50.0000, Cas},
{1.3667, 1.6667, 50.0000, Per},
{6.5000, 6.8000, 50.0000, Lyn},
{23.3333, 24.0000, 50.0000, Cas},
{13.5000, 14.0333, 48.5000, UMa},
{0.0000, 1.1167, 48.0000, Cas},
{23.5833, 24.0000, 48.0000, Cas},
{18.1750, 18.2333, 47.5000, Her},
{18.2333, 19.0833, 47.5000, Dra},
{19.0833, 19.1667, 47.5000, Cyg},
{1.6667, 2.0417, 47.0000, Per},
{8.4167, 9.1667, 47.0000, UMa},
{0.1667, 0.8667, 46.0000, Cas},
{12.0000, 12.0833, 45.0000, UMa},
{6.8000, 7.3667, 44.5000, Lyn},
{21.9083, 21.9667, 44.0000, Cyg},
{21.8750, 21.9083, 43.7500, Cyg},
{19.1667, 19.4000, 43.5000, Cyg},
{9.1667, 10.1667, 42.0000, UMa},
{10.1667, 10.7833, 40.0000, UMa},
{15.4333, 15.7500, 40.0000, Boo},
{15.7500, 16.3333, 40.0000, Her},
{9.2500, 9.5833, 39.7500, Lyn},
{0.0000, 2.5167, 36.7500, And},
{2.5167, 2.5667, 36.7500, Per},
{19.3583, 19.4000, 36.5000, Lyr},
{4.5000, 4.6917, 36.0000, Per},
{21.7333, 21.8750, 36.0000, Cyg},
{21.8750, 22.0000, 36.0000, Lac},
{6.5333, 7.3667, 35.5000, Aur},
{7.3667, 7.7500, 35.5000, Lyn},
{0.0000, 2.0000, 35.0000, And},
{22.0000, 22.8167, 35.0000, Lac},
{22.8167, 22.8667, 34.5000, Lac},
{22.8667, 23.5000, 34.5000, And},
{2.5667, 2.7167, 34.0000, Per},
{10.7833, 11.0000, 34.0000, UMa},
{12.0000, 12.3333, 34.0000, CVn},
{7.7500, 9.2500, 33.5000, Lyn},
{9.2500, 9.8833, 33.5000, LMi},
{0.7167, 1.4083, 33.0000, And},
{15.1833, 15.4333, 33.0000, Boo},
{23.5000, 23.7500, 32.0833, And},
{12.3333, 13.2500, 32.0000, CVn},
{23.7500, 24.0000, 31.3333, And},
{13.9583, 14.0333, 30.7500, CVn},
{2.4167, 2.7167, 30.6667, Tri},
{2.7167, 4.5000, 30.6667, Per},
{4.5000, 4.7500, 30.0000, Aur},
{18.1750, 19.3583, 30.0000, Lyr},
{11.0000, 12.0000, 29.0000, UMa},
{19.6667, 20.9167, 29.0000, Cyg},
{4.7500, 5.8833, 28.5000, Aur},
{9.8833, 10.5000, 28.5000, LMi},
{13.2500, 13.9583, 28.5000, CVn},
{0.0000, 0.0667, 28.0000, And},
{1.4083, 1.6667, 28.0000, Tri},
{5.8833, 6.5333, 28.0000, Aur},
{7.8833, 8.0000, 28.0000, Gem},
{20.9167, 21.7333, 28.0000, Cyg},
{19.2583, 19.6667, 27.5000, Cyg},
{1.9167, 2.4167, 27.2500, Tri},
{16.1667, 16.3333, 27.0000, CrB},
{15.0833, 15.1833, 26.0000, Boo},
{15.1833, 16.1667, 26.0000, CrB},
{18.3667, 18.8667, 26.0000, Lyr},
{10.7500, 11.0000, 25.5000, LMi},
{18.8667, 19.2583, 25.5000, Lyr},
{1.6667, 1.9167, 25.0000, Tri},
{0.7167, 0.8500, 23.7500, Psc},
{10.5000, 10.7500, 23.5000, LMi},
{21.2500, 21.4167, 23.5000, Vul},
{5.7000, 5.8833, 22.8333, Tau},
{0.0667, 0.1417, 22.0000, And},
{15.9167, 16.0333, 22.0000, Ser},
{5.8833, 6.2167, 21.5000, Gem},
{19.8333, 20.2500, 21.2500, Vul},
{18.8667, 19.2500, 21.0833, Vul},
{0.1417, 0.8500, 21.0000, And},
{20.2500, 20.5667, 20.5000, Vul},
{7.8083, 7.8833, 20.0000, Gem},
{20.5667, 21.2500, 19.5000, Vul},
{19.2500, 19.8333, 19.1667, Vul},
{3.2833, 3.3667, 19.0000, Ari},
{18.8667, 19.0000, 18.5000, Sge},
{5.7000, 5.7667, 18.0000, Ori},
{6.2167, 6.3083, 17.5000, Gem},
{19.0000, 19.8333, 16.1667, Sge},
{4.9667, 5.3333, 16.0000, Tau},
{15.9167, 16.0833, 16.0000, Her},
{19.8333, 20.2500, 15.7500, Sge},
{4.6167, 4.9667, 15.5000, Tau},
{5.3333, 5.6000, 15.5000, Tau},
{12.8333, 13.5000, 15.0000, Com},
{17.2500, 18.2500, 14.3333, Her},
{11.8667, 12.8333, 14.0000, Com},
{7.5000, 7.8083, 13.5000, Gem},
{16.7500, 17.2500, 12.8333, Her},
{0.0000, 0.1417, 12.5000, Peg},
{5.6000, 5.7667, 12.5000, Tau},
{7.0000, 7.5000, 12.5000, Gem},
{21.1167, 21.3333, 12.5000, Peg},
{6.3083, 6.9333, 12.0000, Gem},
{18.2500, 18.8667, 12.0000, Her},
{20.8750, 21.0500, 11.8333, Del},
{21.0500, 21.1167, 11.8333, Peg},
{11.5167, 11.8667, 11.0000, Leo},
{6.2417, 6.3083, 10.0000, Ori},
{6.9333, 7.0000, 10.0000, Gem},
{7.8083, 7.9250, 10.0000, Cnc},
{23.8333, 24.0000, 10.0000, Peg},
{1.6667, 3.2833, 9.9167, Ari},
{20.1417, 20.3000, 8.5000, Del},
{13.5000, 15.0833, 8.0000, Boo},
{22.7500, 23.8333, 7.5000, Peg},
{7.9250, 9.2500, 7.0000, Cnc},
{9.2500, 10.7500, 7.0000, Leo},
{18.2500, 18.6622, 6.2500, Oph},
{18.6622, 18.8667, 6.2500, Aql},
{20.8333, 20.8750, 6.0000, Del},
{7.0000, 7.0167, 5.5000, CMi},
{18.2500, 18.4250, 4.5000, Ser},
{16.0833, 16.7500, 4.0000, Her},
{18.2500, 18.4250, 3.0000, Oph},
{21.4667, 21.6667, 2.7500, Peg},
{0.0000, 2.0000, 2.0000, Psc},
{18.5833, 18.8667, 2.0000, Ser},
{20.3000, 20.8333, 2.0000, Del},
{20.8333, 21.3333, 2.0000, Equ},
{21.3333, 21.4667, 2.0000, Peg},
{22.0000, 22.7500, 2.0000, Peg},
{21.6667, 22.0000, 1.7500, Peg},
{7.0167, 7.2000, 1.5000, CMi},
{3.5833, 4.6167, 0.0000, Tau},
{4.6167, 4.6667, 0.0000, Ori},
{7.2000, 8.0833, 0.0000, CMi},
{14.6667, 15.0833, 0.0000, Vir},
{17.8333, 18.2500, 0.0000, Oph},
{2.6500, 3.2833, -1.7500, Cet},
{3.2833, 3.5833, -1.7500, Tau},
{15.0833, 16.2667, -3.2500, Ser},
{4.6667, 5.0833, -4.0000, Ori},
{5.8333, 6.2417, -4.0000, Ori},
{17.8333, 17.9667, -4.0000, Ser},
{18.2500, 18.5833, -4.0000, Ser},
{18.5833, 18.8667, -4.0000, Aql},
{22.7500, 23.8333, -4.0000, Psc},
{10.7500, 11.5167, -6.0000, Leo},
{11.5167, 11.8333, -6.0000, Vir},
{0.0000, 0.3333, -7.0000, Psc},
{23.8333, 24.0000, -7.0000, Psc},
{14.2500, 14.6667, -8.0000, Vir},
{15.9167, 16.2667, -8.0000, Oph},
{20.0000, 20.5333, -9.0000, Aql},
{21.3333, 21.8667, -9.0000, Aqr},
{17.1667, 17.9667, -10.0000, Oph},
{5.8333, 8.0833, -11.0000, Mon},
{4.9167, 5.0833, -11.0000, Eri},
{5.0833, 5.8333, -11.0000, Ori},
{8.0833, 8.3667, -11.0000, Hya},
{9.5833, 10.7500, -11.0000, Sex},
{11.8333, 12.8333, -11.0000, Vir},
{17.5833, 17.6667, -11.6667, Oph},
{18.8667, 20.0000, -12.0333, Aql},
{4.8333, 4.9167, -14.5000, Eri},
{20.5333, 21.3333, -15.0000, Aqr},
{17.1667, 18.2500, -16.0000, Ser},
{18.2500, 18.8667, -16.0000, Sct},
{8.3667, 8.5833, -17.0000, Hya},
{16.2667, 16.3750, -18.2500, Oph},
{8.5833, 9.0833, -19.0000, Hya},
{10.7500, 10.8333, -19.0000, Crt},
{16.2667, 16.3750, -19.2500, Oph},
{15.6667, 15.9167, -20.0000, Lib},
{12.5833, 12.8333, -22.0000, Crv},
{12.8333, 14.2500, -22.0000, Vir},
{9.0833, 9.7500, -24.0000, Hya},
{1.6667, 2.6500, -24.3833, Cet},
{2.6500, 3.7500, -24.3833, Eri},
{10.8333, 11.8333, -24.5000, Crt},
{11.8333, 12.5833, -24.5000, Crv},
{14.2500, 14.9167, -24.5000, Lib},
{16.2667, 16.7500, -24.5833, Oph},
{0.0000, 1.6667, -25.5000, Cet},
{21.3333, 21.8667, -25.5000, Cap},
{21.8667, 23.8333, -25.5000, Aqr},
{23.8333, 24.0000, -25.5000, Cet},
{9.7500, 10.2500, -26.5000, Hya},
{4.7000, 4.8333, -27.2500, Eri},
{4.8333, 6.1167, -27.2500, Lep},
{20.0000, 21.3333, -28.0000, Cap},
{10.2500, 10.5833, -29.1667, Hya},
{12.5833, 14.9167, -29.5000, Hya},
{14.9167, 15.6667, -29.5000, Lib},
{15.6667, 16.0000, -29.5000, Sco},
{4.5833, 4.7000, -30.0000, Eri},
{16.7500, 17.6000, -30.0000, Oph},
{17.6000, 17.8333, -30.0000, Sgr},
{10.5833, 10.8333, -31.1667, Hya},
{6.1167, 7.3667, -33.0000, CMa},
{12.2500, 12.5833, -33.0000, Hya},
{10.8333, 12.2500, -35.0000, Hya},
{3.5000, 3.7500, -36.0000, For},
{8.3667, 9.3667, -36.7500, Pyx},
{4.2667, 4.5833, -37.0000, Eri},
{17.8333, 19.1667, -37.0000, Sgr},
{21.3333, 23.0000, -37.0000, PsA},
{23.0000, 23.3333, -37.0000, Scl},
{3.0000, 3.5000, -39.5833, For},
{9.3667, 11.0000, -39.7500, Ant},
{0.0000, 1.6667, -40.0000, Scl},
{1.6667, 3.0000, -40.0000, For},
{3.8667, 4.2667, -40.0000, Eri},
{23.3333, 24.0000, -40.0000, Scl},
{14.1667, 14.9167, -42.0000, Cen},
{15.6667, 16.0000, -42.0000, Lup},
{16.0000, 16.4208, -42.0000, Sco},
{4.8333, 5.0000, -43.0000, Cae},
{5.0000, 6.5833, -43.0000, Col},
{8.0000, 8.3667, -43.0000, Pup},
{3.4167, 3.8667, -44.0000, Eri},
{16.4208, 17.8333, -45.5000, Sco},
{17.8333, 19.1667, -45.5000, CrA},
{19.1667, 20.3333, -45.5000, Sgr},
{20.3333, 21.3333, -45.5000, Mic},
{3.0000, 3.4167, -46.0000, Eri},
{4.5000, 4.8333, -46.5000, Cae},
{15.3333, 15.6667, -48.0000, Lup},
{0.0000, 2.3333, -48.1667, Phe},
{2.6667, 3.0000, -49.0000, Eri},
{4.0833, 4.2667, -49.0000, Hor},
{4.2667, 4.5000, -49.0000, Cae},
{21.3333, 22.0000, -50.0000, Gru},
{6.0000, 8.0000, -50.7500, Pup},
{8.0000, 8.1667, -50.7500, Vel},
{2.4167, 2.6667, -51.0000, Eri},
{3.8333, 4.0833, -51.0000, Hor},
{0.0000, 1.8333, -51.5000, Phe},
{6.0000, 6.1667, -52.5000, Car},
{8.1667, 8.4500, -53.0000, Vel},
{3.5000, 3.8333, -53.1667, Hor},
{3.8333, 4.0000, -53.1667, Dor},
{0.0000, 1.5833, -53.5000, Phe},
{2.1667, 2.4167, -54.0000, Eri},
{4.5000, 5.0000, -54.0000, Pic},
{15.0500, 15.3333, -54.0000, Lup},
{8.4500, 8.8333, -54.5000, Vel},
{6.1667, 6.5000, -55.0000, Car},
{11.8333, 12.8333, -55.0000, Cen},
{14.1667, 15.0500, -55.0000, Lup},
{15.0500, 15.3333, -55.0000, Nor},
{4.0000, 4.3333, -56.5000, Dor},
{8.8333, 11.0000, -56.5000, Vel},
{11.0000, 11.2500, -56.5000, Cen},
{17.5000, 18.0000, -57.0000, Ara},
{18.0000, 20.3333, -57.0000, Tel},
{22.0000, 23.3333, -57.0000, Gru},
{3.2000, 3.5000, -57.5000, Hor},
{5.0000, 5.5000, -57.5000, Pic},
{6.5000, 6.8333, -58.0000, Car},
{0.0000, 1.3333, -58.5000, Phe},
{1.3333, 2.1667, -58.5000, Eri},
{23.3333, 24.0000, -58.5000, Phe},
{4.3333, 4.5833, -59.0000, Dor},
{15.3333, 16.4208, -60.0000, Nor},
{20.3333, 21.3333, -60.0000, Ind},
{5.5000, 6.0000, -61.0000, Pic},
{15.1667, 15.3333, -61.0000, Cir},
{16.4208, 16.5833, -61.0000, Ara},
{14.9167, 15.1667, -63.5833, Cir},
{16.5833, 16.7500, -63.5833, Ara},
{6.0000, 6.8333, -64.0000, Pic},
{6.8333, 9.0333, -64.0000, Car},
{11.2500, 11.8333, -64.0000, Cen},
{11.8333, 12.8333, -64.0000, Cru},
{12.8333, 14.5333, -64.0000, Cen},
{13.5000, 13.6667, -65.0000, Cir},
{16.7500, 16.8333, -65.0000, Ara},
{2.1667, 3.2000, -67.5000, Hor},
{3.2000, 4.5833, -67.5000, Ret},
{14.7500, 14.9167, -67.5000, Cir},
{16.8333, 17.5000, -67.5000, Ara},
{17.5000, 18.0000, -67.5000, Pav},
{22.0000, 23.3333, -67.5000, Tuc},
{4.5833, 6.5833, -70.0000, Dor},
{13.6667, 14.7500, -70.0000, Cir},
{14.7500, 17.0000, -70.0000, TrA},
{0.0000, 1.3333, -75.0000, Tuc},
{3.5000, 4.5833, -75.0000, Hyi},
{6.5833, 9.0333, -75.0000, Vol},
{9.0333, 11.2500, -75.0000, Car},
{11.2500, 13.6667, -75.0000, Mus},
{18.0000, 21.3333, -75.0000, Pav},
{21.3333, 23.3333, -75.0000, Ind},
{23.3333, 24.0000, -75.0000, Tuc},
{0.7500, 1.3333, -76.0000, Tuc},
{0.0000, 3.5000, -82.5000, Hyi},
{7.6667, 13.6667, -82.5000, Cha},
{13.6667, 18.0000, -82.5000, Aps},
{3.5000, 7.6667, -85.0000, Men},
{0.0000, 24.0000, -90.0000, Oct},
{0.0000, 24.0000, -90.0000, ""}
};
/* given ra and dec (in rads) precessed to epoch e (an mjd)
* point *name to a string naming the constellation at that location.
*/
static
confnd(r, d, e, name)
double r, d, e;
char **name;
{
double ra1875, de1875, mjd1875;
int i;
cal_mjd (1, 1.0, 1875, &mjd1875);
precess (e, mjd1875, &r, &d);
/* find constellation such that the declination entered is higher than
* the lower boundary of the constellation when the upper and lower
* right ascensions for the constellation bound the entered right
* ascension
*/
i = 0;
ra1875 = radhr (r);
de1875 = raddeg (d);
while ((con_data[i].l_dec > de1875 || con_data[i].u_ra <= ra1875
|| con_data[i].l_ra > ra1875) && con_data[i].cons[0])
i++;
*name = con_data[i].cons[0] ? con_data[i].cons : "<No constellation?!>";
}